Enable Java Engine Logging
Java Report Engine uses log4j for its logging. Log4j must be configured both for the cases where the embedding application using Java Report Engine also uses log4j, and for the case where Java Engine is the only component using log4j. (Note that WindwardReportsServer.jar must use the log4j configuration file.)
Java Report Engine can't just turn off logging because that would cause problems for embedding application components using log4j. There is no way for Java Report Engine to know if log4j is being used elsewhere.
Your three options are:
If you use log4j and you initialize it before calling Java Report Engine, then delete the
logging.filename=...
entry in WindwardReports.properties. In this case Java Report Engine assumes log4j is already initialized.If you use log4j but do not initialize it before first calling Java Report Engine, then set the
logging.filename=...
entry in WindwardReports.properties to point to your log4j.properties file. This entry is first tried as a URL and if that fails, then as a filename. (Note that a filename is not a legitimate URL.)
For more information on log4j configuration, please refer to the log4j documentation. The filename you set for log4j is passed to log4j using the call (logFile
is the string from the property logging.filename
):
And if that fails, then:
- To turn logging off (this is not recommended), set the entry to:
If you do not use log4j elsewhere, then set logging.filename=log4j.properties
(fully specify the file location) and create a log4j.properties file.
For standard logging, we suggest these properties:
For debug logging (when requested by Support), use these properties:
#
Log4j Settings to Log All Engine ComponentsJava Report Engine makes use of several 3rd-party libraries. To turn on logging for all components you must set log4j to enable logging for all of the following classes:
tip
If logging is slowing you down, please see this article from Apache to remove or disable unneeded loggers, appenders or layouts.